<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <link rel="stylesheet" href="./libs/layui/css/layui.css">
    <script src="./libs/jquery/jquery.min.js"></script>
    <script src="./libs/layui/layui.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <div class="form-inline">
                        <input type="text" id="aname" class="form-control input-sm" placeholder="输入文章标题...">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>

                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </div>
                </div>
                <div class="col-xs-6">
                    <a href="article_add.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div id="test1" class="row text-center">
            </div>
        </div>
    </div>
    <!-- 引入模板引擎 -->
    <script src="./libs/art-template/template-web.js"></script>
    <!-- 1.0 定义文章分类下拉框中的模板 -->
    <script id="art_cate" type="text/html">
        {{each data}}
        <option value="{{$value.id}}">{{$value.name}}</option>
        {{/each}}
    </script>
    <!-- 2.0  定义文章列表模板-->
    <script id="art_list" type="text/html">
        {{each data}}
        <tr>
            <td>{{$value.title}}</td>
            <td>{{$value.author}}</td>
            <td>{{$value.category}}</td>
            <td class="text-center">{{$value.date}}</td>
            <td class="text-center">{{$value.state}}</td>
            <td class="text-center">
                <a href="article_edit.html?id={{$value.id}}" class="btn btn-default btn-xs">编辑</a>
                <a href="javascript:void(0);" onclick="del({{$value.id}})" class="btn btn-danger btn-xs delete">删除</a>
            </td>
        </tr>
        {{/each}}
    </script>
    <!-- 引入js -->
    <script src="./js/http.js"></script>
    <script>
        $(function () {
            //1.0 获取文章分类下拉框数据
            get_cate_list();
            // 2.0 获取所有的文章数据
            get_list();
            // 3.0 给筛选按钮注册点击事件
            $('#btnSearch').click(function () {
                get_list();
            });
        });

        function render_pager(totalcount, currentpage = 1) {
            // 生成分页条码控件
            layui.use('laypage', function () {
                var laypage = layui.laypage;

                //执行一个laypage实例
                laypage.render({
                    elem: 'test1' //注意，这里的 test1 是 ID，不用加 # 号
                        ,
                    count: totalcount //数据总数，从服务端得到
                        ,
                    curr: currentpage,
                    limit: 6,
                    jump: function (obj, first) {
                        //obj包含了当前分页的所有参数，比如：
                        console.log(obj.curr); //得到当前页，以便向服务端请求对应页的数据。
                        console.log(obj.limit); //得到每页显示的条数                       
                        console.log(first);
                        //首次不执行
                        if (!first) {
                            //do something
                            get_list(obj.curr, obj.limit);
                        }
                    }
                });
            });
        }

        // 获取文章分类数据
        function get_cate_list() {

            myAjax('get', '/admin/category/list', null, function (resData) {
                // 响应回来文章分类数据
                /* 
                 {"code":200,"msg":"获取成功","data":[{"id":1,"name":"爱生活","slug":"热爱生活"}]}
                */
                //将 resData.data数组通过art-template生成一个html结构
                let optHtml = template('art_cate', resData);
                // 将optHtml追加到id=selCategory 的select元素中
                $('#selCategory').append(optHtml);

            });
        }
        // 获取所有的文章数据
        function get_list(page = 1, perpage = 6) {
            // 1.0 获取参数
            let parms = {
                key: $('#aname').val(), //表示要搜索的文章标题关键字
                type: $('#selCategory').val(), //文章的分类
                state: $('#selStatus').val(), //文章的发布状态，草稿，已发布
                page: page, //当前的分页页码
                perpage: perpage, //当前一页要显示的数据条数，默认是6条
            }
            myAjax('get', '/admin/article/query', parms, function (resData) {
                // console.log(resData);
                /* 
                            {
                            "code": 200,
                            "msg": "数据获取成功",
                            "data": {
                                "totalCount": 220,
                                "totalPage": 37,
                                "data": [{
                                    "id": 220,
                                    "title": "借美团点评发布最佳财报之际，我们讨论一下估值分歧 | 见智研究团队",
                                    "cover": "http://localhost/https://wpimg.wallstcn.com/9778718c-e680-4cef-88ad-9b62f21043a8.jpg",
                                    "date": "2019-05-28",
                                    "content": "见智对美团点评的“分部估值法”持有保留意见，两种估值方法得到截然相反的估值结果，本质上是对外卖业务的价值评估分歧。",
                                    "state": "已发布",
                                    "author": "管理员",
                                    "read": 134,
                                    "categoryId": 1,
                                    "category": "爱生活"
                                }]
                            }
                        }
                */
                // 调用生成分页控件
                render_pager(resData.data.totalCount, page);

                let optHtml = template('art_list', resData.data);
                $('.table tbody').html(optHtml);
            })
        }
        // 删除文章方法
        function del(a_id) {
            // 调用接口删除文章
            myAjax('post', '/admin/article/delete', {
                id: a_id
            }, function (resData) {
                // 重新获取页面数据
                get_list();
            })
        }
    </script>
</body>

</html>